**OBJECTIVE:** Create an 8-bit adder and an 8-bit subtracter.

**PROCEDURE:** First import the halfadder, fulladder, RippleCarry4 module source files from the previous lab. Be sure to use the exact same file names from the previous lab.

Next create an 8-bit Ripple carry adder using 2 of the 4-bit ripple carry adders according to the block diagram below:



Name the file **ripplecarry8.v** and use the module skeleton below to get started:

```
'include "ripplecarry4.v"
  module RippleCarry8(input cin,
3
                        input [7:0] a, b,
                        output [7:0] s,
4
5
                        output cout);
    wire cout3;
6
7
    RippleCarry4
    rc40(cin, a[3:0], b[3:0], s[3:0], cout3),
8
9
     rc41(
10 endmodule
```

Then create an 8-bit ripple subtracter according to the block diagram below:



Create a file named **ripplesubtracter8.v** and use the skeleton code below to get started:

```
module RippleSubtracter8(input bin,
  2
                         input [7:0] a, b,
  3
                              output [7:0] d,
  4
                         output bout);
  5
      wire [7:0] e;
  6
      xor
      x0(e[0], ,bin),
  7
      x1(e[1],
                  ,bin),
  8
  9
      x2(e[ ],
                  ,bin),
      x3(e[],
                  ,bin),
 10
      x4(e[ ],b[4],
 11
      x5(e[],b[5],
 12
      x6(e[6],b[6],
 13
                      Э,
      x7(e[7],b[7],
 14
 15
      RippleCarry8
 16
      rs(bin,
                          );
 17
               , e, ,
18 endmodule
```

Leave the **design.sv** file empty as we will not be using it in this project.

Source code for testbench.sv is provided below:

```
SV/Verilog Testben
  `include "ripplecarry8.v"
2 `include "ripplesubtracter8.v"
3 module ripplecarrytester;
    reg [7:0] a,b; reg add0_sub1;
4
    wire [7:0] sum, difference;
5
6
    integer i;
7
8
     RippleCarry8 //instantiate 8-bit Adder
9
     uut0(add0_sub1, a,b,sum,);
10
11
12
     RippleSubtracter8 //instantiate 8-bit Subtracter
     uut1(add0_sub1, a, b, difference,);
13
14
15
    initial begin
       $display("\n\n");
16
       for(i = 0; i < 10; i = i + 1) begin
17
         {a,b,add0_sub1}=$random; test_case;
18
       end
19
       $finish;
20
21
    end
22
    task test_case;
23
24
       #1
       if(add0_sub1==1'b0) begin
25
         $display("\nAdder Test");
26
         display("a = \%b, b = \%b, sum = \%b",a,b,sum);
27
28
       end
       else begin
29
         $display("\nSubtracter Test");
30
         $display("a = %b, b = %b, difference = %b",a,b,difference);
31
32
       end
33
     endtask
34 endmodule
```

If everything works correctly then the following console output will be produced:

```
Adder Test
a = 10011010, b = 10010010, sum = 00101100
Subtracter Test
a = 10101111, b = 01000000, difference = 01101111
Subtracter Test
a = 01101011, b = 00000100, difference = 01100111
Subtracter Test
a = 00101011, b = 00110001, difference = 11111010
Subtracter Test
a = 10111101, b = 10000110, difference = 00110111
Subtracter Test
a = 11001100, b = 11000110, difference = 00000110
Subtracter Test
a = 01000010, b = 00110010, difference = 00010000
Adder Test
a = 10101001, b = 00001001, sum = 10110010
Subtracter Test
a = 11110001, b = 10000000, difference = 01110001
Subtracter Test
a = 11100110, b = 10000110, difference = 01100000
Done
```

If your module did not work correctly get assistance from the instructor or a reputable student to troubleshoot your design.

**WHAT TO TURN IN:** Once the modules in this lab are working correctly:

- Copy the contents of your ripplecarry8.v module to a file named ripplecarry8.txt
- upload <u>ripplecarry8.txt</u> to the beachboard dropbox for <u>ripplecarry8</u>
- Copy the contents of your ripplesubtracter8.v module to a file named ripplesubtracter8.txt
- upload <u>ripplesubtracter8.txt</u> to the beachboard dropbox for ripplesubtracter8

#### NOTE:

Keep the source files from this lab as they will be used in future Labs!

halfadder, fulladder, ripplecarry4, ripplecarry8, and ripplesubtracter8 modules will be used in upcoming labs.